<template>
  <!-- 当todos的长度为0时，就让div隐藏。注意0为false -->
  <div class="todo-footer" v-show="todos.length">
    <label>
      <input type="checkbox" :checked="allCheck" @change="checkAll" />
    </label>
    <span>
      <span>已完成{{ doneTotal }} </span> / 全部{{ todos.length }}
    </span>
    <button class="btn btn-danger" @click="clearAll">清除已完成任务</button>
  </div>
</template>

<script>
export default {
  name: "MyFooter",
  props: ["todos"],
  computed: {
    // 计算已经完成的todo数量
    doneTotal() {
      // 统计数组使用reduce
      const res = this.todos.reduce((pre, cur) => {
        return pre + (cur.done ? 1 : 0);
      }, 0);
      return res;
    },

    // 计算底部是否全选
    allCheck() {
      // 在计算属性里面可以调用其它计算属性
      // 注意bug：当todos里面的数据全被删除即长度为0时，全选框不应选中
      return this.doneTotal == this.todos.length && this.todos.length > 0;
    },
  },
  methods: {
    // 全选
    checkAll(e) {
      // this.checkAllTodo(e.target.checked);
      this.$emit("checkAllTodo", e.target.checked);
    },

    // 全部清除
    clearAll() {
      // this.clearAllTodo();
      this.$emit("clearAllTodo");
    },
  },
};
</script>

<style>
/*footer*/
.todo-footer {
  height: 40px;
  line-height: 40px;
  padding-left: 6px;
  margin-top: 5px;
}

.todo-footer label {
  display: inline-block;
  margin-right: 20px;
  cursor: pointer;
}

.todo-footer label input {
  position: relative;
  top: -1px;
  vertical-align: middle;
  margin-right: 5px;
}

.todo-footer button {
  float: right;
  margin-top: 5px;
}
</style>